//给定单链表的头节点 head ，将所有索引为奇数的节点和索引为偶数的节点分别组合在一起，然后返回重新排序的列表。 
//
// 第一个节点的索引被认为是 奇数 ， 第二个节点的索引为 偶数 ，以此类推。 
//
// 请注意，偶数组和奇数组内部的相对顺序应该与输入时保持一致。 
//
// 你必须在 O(1) 的额外空间复杂度和 O(n) 的时间复杂度下解决这个问题。 
//
// 
//
// 示例 1: 
//
// 
//
// 
//输入: head = [1,2,3,4,5]
//输出: [1,3,5,2,4] 
//
// 示例 2: 
//
// 
//
// 
//输入: head = [2,1,3,5,6,4,7]
//输出: [2,3,6,7,1,5,4] 
//
// 
//
// 提示: 
//
// 
// n == 链表中的节点数 
// 0 <= n <= 10⁴ 
// -10⁶ <= Node.val <= 10⁶ 
// 
//
// Related Topics 链表 👍 746 👎 0


package LeetCode.editor.cn;

/**
 * @author ldltd
 * @date 2023-10-02 10:02:32
 * @description 328.奇偶链表
 */
public class OddEvenLinkedList{
	 public static void main(String[] args) {
	 	 //测试代码
	 	 Solution solution = new OddEvenLinkedList().new Solution();

	 }
	 
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)

  //Definition for singly-linked list.
  public class ListNode {
     int val;
     ListNode next;
      ListNode() {}
      ListNode(int val) { this.val = val; }
      ListNode(int val, ListNode next) { this.val = val; this.next = next; }
  }

class Solution {
    public ListNode oddEvenList(ListNode head) {
		if(head==null||head.next==null) return head;
		ListNode e1=head.next,e2=head.next,o1=head,o2=head;
        while (o1.next!=null&&e1.next!=null){
            o1.next=o1.next.next;
            o1=o1.next;
            e1.next=e1.next.next;
            e1=e1.next;
        }
        o2.next=e2;
        return o2;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
